php - 最多匹配 x 正则表达式或 y 正则表达式
全部标签 我正在使用Ruby的正则表达式引擎。我需要编写一个执行此操作的正则表达式WIKI_WORD=/\b([a-z][\w_]+\.)?[A-Z][a-z]+[A-Z]\w*\b/但也可以使用除英语以外的其他欧洲语言。我认为字符范围[a-z]不会涵盖德语等的小写字母。 最佳答案 WIKI_WORD=/\b(\p{Ll}\w+\.)?\p{Lu}\p{Ll}+\p{Lu}\w*\b/u应该在Ruby1.9中工作。\p{Lu}和\p{Ll}是大写和小写Unicode字母的简写。(\w已经包含下划线)另见thisanswer-您可能需要在UTF
我知道在Ruby中,几乎所有东西都是表达式。即使是其他语言中的if-else语句、case语句、赋值语句、loop语句在Ruby中也是表达式。所以我想从Ruby的角度了解,statement和expression有什么区别? 最佳答案 Ruby中表达式和语句没有区别。一切都计算为一个值,所以一切都是表达式。 关于ruby-Ruby中的语句和表达式有什么区别?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c
在ruby1.9.3中,正则表达式引擎不会将nbsp的(\u00A0)视为空格(\s)。这对我来说常常是一个无赖。所以我的问题是,这会在2.0中改变吗?如果没有,是否有任何方法可以修补解决方案? 最佳答案 使用Unicode属性(你需要声明一个匹配的源代码编码才能工作):#encoding=utf-8ifsubject~=/\p{Z}/#subjectcontainswhitespaceorotherseparators或使用POSIX字符类:ifsubject~=/[[:space:]]/根据thedocs,\s现在和将来只会
我想匹配格式为A0123456、E0123456或IN:A0123456Q等格式的字符串,我原来做的是这个regex^(IN:)?[AE][0-9]{7}Q?$但它匹配IN:E012346而末尾没有Q。所以我创建了这个正则表达式(^IN:[AE][0-9]{7}Q$)|(^[AE][0-9]{7}$)有什么方法可以缩短这个正则表达式,使其同时需要IN:和Q如果它们存在,但如果两者都不存在则不需要?编辑:正则表达式将在Ruby中使用。编辑2:我更改了正则表达式以反射(reflect)我匹配了错误的字符串,因为它仍然匹配IN:A0123456。编辑3:下面的两个答案都是有效的,但由于我使用
我有一个很长的文本,我想用空格替换其中的点,但只能在文本的中间。例如:Domain:...................google.com我需要这样:Domain:google.com我发现了这个用单个空格替换点的正则表达式:str.gsub!(/(?但这还不够,因为它会产生:Domain:google.com我需要保留与点一样多的空格。你会如何解决? 最佳答案 你快到了,你的正则表达式没问题,只需使用String#gsub的block版本计算替换匹配的长度:▶str='Domain:...................goo
是否可以在gsub表达式中使用否定匹配?我想替换以hello开头的字符串except以helloPeter开头的字符串>my-string.gsub(/^hello@/i,'')我应该用什么代替@? 最佳答案 听起来你想要一个负面的前瞻:>>"hellofoo".gsub(/hello(?!peter)/,'lala')#=>"lalafoo">>"hellopeter".gsub(/hello(?!peter)/,'lala')#=>"hellopeter" 关于ruby-在正则表达式
(irb)a,b=5a=>5b=>nil不应该反过来吗?这里到底发生了什么? 最佳答案 在我写这篇文章时,我的同事发现了原因:Ruby将a,b=5视为a,b=5,nil在Python3中,抛出一个TypeError。 关于ruby-on-rails-为什么表达式"a,b=5"在Ruby中将a设置为5,而将b设置为nil?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/314621
制作参数解析器。我想将一个字符串拆分为一个分隔符为","的数组除非前面有"|".这意味着字符串"foo,ba|,r,arg"应该导致`["foo","ba|,r","arg"]`我正在尝试使用这个正则表达式:(?适用于http://regexhero.net/tester/但是当我尝试args.split(/(?在ruby中,我得到一个错误:undefined(?...)sequence:/(? 最佳答案 Ruby的正则表达式引擎还不支持lookbehind。您需要切换到1.9或使用Oniguruma.如果这不是一个选项,您可以
我想这将是一个愚蠢的错误,但对我来说,以下返回一个仅包含“M”的数组。看这个:/(.)+?/.match("Manymanycharacters!").captures=>["M"]为什么它不返回每个字符的数组?我一定是错过了一些明显的东西,因为我看不出这有什么问题?编辑:刚刚意识到,我不需要+?但没有它仍然无法工作。编辑:抱歉!我会澄清:我的目标是让用户输入正则表达式和样式以及输入文本文件,只要有匹配项,文本就会被html元素包围并应用样式,我不只是拆分将字符串转换为字符,我只使用了给定的正则表达式,因为它是最简单的,尽管这对我来说很愚蠢。我如何从scan()获取捕获组或者这是不可能
假设有下面这个类#derp.rbclassDerp当我加载“./derp.rb”两次时,程序因TypeError:superclassmismatchforclassDerp而失败。好的,这可以通过require来管理。但是我如何为每次使用Spork的测试运行重新加载这些类?require显然不会工作,因为它会缓存加载的文件。 最佳答案 Struct.new正在为您的每次加载创建新类。irb(main):001:0>classTest1classTest1'您可以将返回的Struct.newclass保存到一个变量中,然后您可以使用